<template>
	<section>
		<!--工具条-->
		<el-col :span="24" class="toolbar" style="padding-bottom: 0px;">
			<el-form :inline="true" :model="filters">
				<el-form-item>
					<el-input v-model="filters.keyword" placeholder="关键字" size="small"></el-input>
				</el-form-item>
				<el-form-item>
					<el-button type="primary" v-on:click="getTableData" icon="el-icon-search" size="small">查询</el-button>
				</el-form-item>
				<el-form-item>
					<el-button type="primary"  icon="el-icon-plus" size="small"  v-on:click="add" >新增</el-button>
				</el-form-item>
			</el-form>
		</el-col>

		<!--列表-->
		<el-table :data="tableData" highlight-current-row v-loading="listLoading" @selection-change="selsChange" style="width: 100%;">
			<el-table-column type="selection" width="55">
			</el-table-column>
			<el-table-column prop="sendTime" label="时间" width="150" >
			</el-table-column>
			<el-table-column prop="userId" label="用户" width="150" >
			</el-table-column>
			<el-table-column prop="ip" label="ip" width="120" >
			</el-table-column>
			<el-table-column prop="phone" label="手机号" width="120" >
			</el-table-column>
			<el-table-column prop="title" label="标题" width="100"  >
			</el-table-column>
			<el-table-column prop="content" label="内容" width="200" >
				<template slot-scope="scope">
					<el-popover trigger="hover" placement="top" >
						<div style="max-width: 400px;">{{ scope.row.content }}</div>
						<div slot="reference" class="name-wrapper" >
							<el-tag >
								{{ scope.row.content }}
							</el-tag>
						</div>
					</el-popover>
				</template>
			</el-table-column>
			<el-table-column label="操作" >
				<template scope="scope">
          <el-button type="danger" size="small" @click="block(scope.row)" icon="el-icon-error">拉黑</el-button>
					<el-button size="small"  @click="edit(scope.row)" icon="el-icon-edit" type="primary">编辑</el-button>
					<el-button type="danger" size="small" @click="del(scope.row)" icon="el-icon-remove">删除</el-button>
				</template>
			</el-table-column>
		</el-table>

		<!--工具条-->
		<el-col :span="24" class="toolbar">
			<el-button type="danger" @click="batchRemove" :disabled="this.sels.length===0" icon="el-icon-remove" size="small">批量删除</el-button>
      <el-pagination layout="prev, pager, next" @current-change="handleCurrentChange" :page-size="20" :total="total" style="float:right;">
      </el-pagination>
		</el-col>

    <!--黑名单-->
    <el-dialog title="加入黑名单" :visible.sync="saveBlockVisible" :close-on-click-modal="false">
      <el-form :model="saveBlock" label-width="80px" :rules="saveBlockRules" ref="saveBlock">
        <el-form-item label="手机号" prop="phone">
          <el-input v-model="saveBlock.phone" auto-complete="off"></el-input>
        </el-form-item>
        <el-form-item label="拉黑原因" prop="intro">
          <el-input v-model="saveBlock.intro" auto-complete="off"></el-input>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button @click.native="saveBlockVisible = false">取消</el-button>
        <el-button type="primary" @click.native="saveSubmit" :loading="saveLoading">提交</el-button>
      </div>
    </el-dialog>

	</section>
</template>

<script>

	export default {
		data() {
			return {
				filters: {
					keyword: ''
				},
				tableData: [],
				total: 0,
				page: 1,
				listLoading: false,
				sels:[],

        saveBlockVisible: false,//编辑界面是否显示
        saveLoading: false,
        saveBlockRules: {
          intro: [
            { required: true, message: '请输入拉黑原因', trigger: 'blur' }
          ]
        },
        //编辑界面数据
        saveBlock: {
          phone: '',
          ip: '',
          intro: ''
        },

			}

		},
		methods: {
			selsChange(sels){
				this.sels = sels;
			},
			handleCurrentChange(val) {
				this.page = val;
				this.getTableData();
			},
			//获取用户列表
			getTableData() {
				let para = {
					page: this.page,
					keyword: this.filters.keyword
				};
				this.listLoading = true; //显示加载圈
				this.$http.post("/common/messageSms/pagelist",para).then(result=>{
					this.total = result.data.data.total;
					this.tableData = result.data.data.rows;
					this.listLoading = false;  //关闭加载圈
				}).catch(error => {
					this.listLoading = false;
					this.$message({ message: "数据加载失败["+error.message+"]", type: 'error' });

				})
			},
			edit(){
				this.$message({ message: "功能未开放", type: 'error' });
			},
			del(){
				this.$message({ message: "功能未开放", type: 'error' });
			},
			batchRemove(){
				this.$message({ message: "功能未开放", type: 'error' });
			},
			add(){
				this.$message({ message: "功能未开放", type: 'error' });
			},
      block: function (row) {
        this.saveBlock = Object.assign({}, row);
        this.saveBlockVisible = true;
        this.saveBlock.phone = row.phone;
      },
      saveSubmit: function () {
        this.$refs.saveBlock.validate((valid) => {
          if (valid) {
            this.$confirm('确认提交吗？', '提示', {}).then(() => {
              this.saveLoading = true;
              this.$http.post("/common/messageBlack/onBlack",this.saveBlock).then(res=>{
                if(res.data.success){
                  this.getTableData();
                }else {
                  alert(res.data.message)
                }
                this.saveLoading = false;
              }).catch(res=>{
                this.$message.error("系统繁忙(404/400),请稍后重试！")
                this.saveLoading = false;
              })
              // 关闭对话框
              this.saveBlockVisible = false;
            });
          }
        });
      },

		},
		mounted() {
			this.getTableData();
		}
	}

</script>

<style scoped>

</style>